Multiprocesadores: Práctica 2

## **Multiprocesadores: Práctica 2**

Eric Rufart y David Soldevila Grupo 11

Trabajo 2: Muestre en sendos diagramas temporales de retardos un acceso de lectura y un acceso de escritura. Los retardos deben indicarse en el instante de tiempo más tardío en que pueden producirse para un funcionamiento correcto. Indique los retardos que pueden afectar a un valor, tanto en una posición de almacenamiento como en un puerto de salida. Utilice una señal de reloj cuadrada con periodo de 10 ns como referente. Utilice los valores de retardo especificados en el Apéndice 2.16 (ret\_deco\_dat, ret\_dat\_leer, ret\_dat\_esc)., en la página 5.





En el cuadro 1 podemos observar los retardos de los componentes en una operación de lectura. La lectura requiere de 3 ns que se corresponden al retardo ret\_dat\_leer y siendo los últimos 3 ns del ciclo el momento más tardío en el que se ejecuta correctamente. Dado que la lectura es síncrona con el reloj los valores deben ser decodificados antes del flanco ascendente anterior a esta y como el retardo de decodificación son 2ns, ret\_deco\_dat, debe haberse estabilizado durante los dos últimos nanosegundos del ciclo anterior.

Respecto a la escritura, observable en el cuadro 2, la lectura y decodificación siguen las mismas normas, pero se le añade un retraso de 2ns a la lectura por culpa de la escritura.

Trabajo 9: Para el controlador de caché de la Figura 16, construya una tabla de transiciones entre estados (Apéndice 2.3), donde también se especifique la lógica de salida en la segunda subfila de cada estado (activación, desactivación de las señales). En el caso de la lógica de salida indique sólo la activación de la señal (valor 1). Suponga que por defecto las señales no se activan.,

|         |        | Procesado                  | or                     |        | Señales     | de estado     |        | Men     | noria  |                                                                     |
|---------|--------|----------------------------|------------------------|--------|-------------|---------------|--------|---------|--------|---------------------------------------------------------------------|
| Estados | Petio  | ción                       |                        | lect   | tura        | escri         | itura  | resp. m | emoria |                                                                     |
| Ì       | inicio | !inicio                    | !Petición              | si     | no          | si            | no     | si      | no     |                                                                     |
|         | INI    | CMPET                      | DES0                   |        |             |               |        |         |        |                                                                     |
| DES0    | nada   | nada<br>ET_acc,<br>EST_acc | desocupada<br>pc_listo |        |             |               |        |         |        |                                                                     |
| INI     |        |                            |                        |        |             |               |        |         |        | ESCINI                                                              |
|         |        |                            |                        |        |             |               |        |         |        |                                                                     |
|         |        |                            |                        |        |             |               |        |         |        | HECHOE                                                              |
| ESCINI  |        |                            |                        |        |             |               |        |         |        | actualiza<br>campos,ET_esc,<br>EST_esc,<br>DAT_esc,<br>EST_DE, muxE |
|         |        | CMPET                      | DES                    |        |             |               |        |         |        |                                                                     |
| DES     |        | nada<br>ET_acc,<br>EST_acc | desocupada<br>pc_listo |        |             |               |        |         |        |                                                                     |
| СМРЕТ   |        |                            |                        | LEC    | PML         | PMEA          | PMEF   |         |        |                                                                     |
|         |        |                            |                        | leer e | tiqu. y com | parar, leer e | estado |         |        |                                                                     |
| LEC     |        |                            |                        |        |             |               |        |         |        | HECHOL                                                              |
|         |        |                            |                        |        |             |               |        |         |        | lec campo dato<br>DAT_ACC                                           |
|         |        |                            |                        |        |             |               |        |         |        | DES                                                                 |
| HECHOL  |        |                            |                        |        |             |               |        |         |        | inidicacion de<br>dato<br>rc_val                                    |
|         |        |                            |                        |        |             |               |        |         |        | ESPL                                                                |
| PML     |        |                            |                        |        |             |               |        |         |        | pet. lec.<br>memoria<br>pm_val                                      |
| ESPL    |        |                            |                        |        |             |               |        | ESB     | ESPL   |                                                                     |
|         |        |                            |                        |        |             |               |        | nada    | nada   |                                                                     |
|         |        |                            |                        |        |             |               |        |         |        | LEC                                                                 |
| ESB     |        |                            |                        |        |             |               |        |         |        | actualiza<br>campos<br>ET_esc,<br>EST_esc,<br>DAT_esc,<br>EST_DE    |
|         |        |                            |                        |        |             |               |        |         |        | ESPEA                                                               |
| PMEA    |        |                            |                        |        |             |               |        |         |        | pet. esc.<br>memoria<br>pm_esc                                      |
| ESPEA   |        |                            |                        |        |             |               |        | ESCP    | ESPEA  |                                                                     |
| -5. LA  |        |                            |                        |        |             |               |        | nada    | nada   |                                                                     |
|         |        |                            |                        |        |             |               |        |         |        | HECHOE                                                              |
| ESPC    |        |                            |                        |        |             |               |        |         |        | actualiza<br>campos<br>DAT_esc                                      |
|         |        |                            |                        |        |             |               |        |         |        | ESPEF                                                               |
| PMEF    |        |                            |                        |        |             |               |        |         |        | pet. esc.<br>memoria<br>pm_esc                                      |
| ESPEF   |        |                            |                        |        |             |               |        | НЕСНОЕ  | ESPEF  |                                                                     |
|         |        |                            |                        |        |             |               |        | nada    | nada   |                                                                     |
| HECHOE  |        |                            |                        |        |             |               |        |         |        | DES                                                                 |

Multiprocesadores: Práctica 2

| nada nada |
|-----------|
|-----------|

Trabajo 13: Analice el programa de prueba. Describa los procesos "productor" y "consumidor" mediante diagramas temporales. Así mismo, describa los procedimientos "Plectura" y "Pescritura". Para ello, utilice la señal reloj y sus flancos como referente. Céntrese en el protocolo de las interfaces: comunicación entre el procesador y la cache y viceversa., en la página 16.

Se genera una peticion de lectura en la etapa Plectura ocn el valor adecuado en "esperando" tra el fanco descendente y acaba de poner "pet" con un retardo. Tras el siguiente flanco ascendente se pone en "listo" a 1 y la cache procesa el valor pedido, esto tardara un tiempo "t.procesar".



"Pescritura" empieza generando la petición de escritura en función del dato y la dirección suministrada. Seguidamente activa la señal de listo y despues un tiempo de procesamiento la caché procesa el dato.



Trabajo 23: Construya una secuencia con el mínimo número de accesos, que muestre una comprobación incremental del diseño. Para este trabajo utilice una única entrada de cache. Muestre en una tabla la información actualizada en cada acceso del programa de prueba., en la página 17

Cada fila de la tabla muestra un acceso a cache junto al estado de la cache y la memoria en el momento en el que se inicia el acceso. La última fila muestra el estado al finalizar todos los accesos.

| ciclo |       |         |            | Memo   | lemoria Cache |          |               |       |      |              | Camino que   |  |  |  |
|-------|-------|---------|------------|--------|---------------|----------|---------------|-------|------|--------------|--------------|--|--|--|
|       | Tipo  | Direcci | Tranacció' | Variab | Val           | Contened | <b>Etique</b> | Varia | Valo | <b>Estad</b> | se           |  |  |  |
|       |       | ón      | n          | le     | or            | or       | ta            | ble   | r    | 0            | comprueba    |  |  |  |
| 4     | Store | 0000    | PtE        | 0000   | Χ             | 0        | XXX           | XXXX  | Χ    | Χ            | STORE - MISS |  |  |  |
| 13    | Load  | 0000    | Pt         | 0000   | 1             | 0        | XXX           | XXXX  | Χ    | Χ            | LOAD - MISS  |  |  |  |
| 24    | Load  | 0000    |            | 0000   | 1             | 0        | 000           | 0000  | 1    | 1            | LOAD - HIT   |  |  |  |
| 28    | Store | 0000    | PtE        | 0000   | 1             | 0        | 000           | 0000  | 1    | 1            | STORE - HIT  |  |  |  |
| 38    |       |         |            | 0000   | 42            | 0        | 000           | 0000  | 42   | 1            |              |  |  |  |

Trabajo 24: Una vez esté completamente implementado el controlador de cache, prepare una secuencia de accesos a memoria que compruebe el funcionamiento de forma exhaustiva (comprobar entradas distintas, entrelazar sin accesos consecutivos, accesos a la misma y distinta dirección, conflictos en cache)., en la página 17.

| Tipo  | Direccion | Descripción                       |
|-------|-----------|-----------------------------------|
| Store | 0000      | Store con Miss contenedor 0       |
| Load  | 0000      | Load con Miss contenedor 0        |
| Load  | 0000      | Load con HIT contenedor 0         |
| Store | 0000      | Store con HIT contenedor 0        |
| Store | 0001      | Store con Miss contenedor 1       |
| Load  | 0001      | Load con Miss contenedor 1        |
| Load  | 0001      | Load con HIT contenedor 1         |
| Load  | 0009      | Load MISS contenedor 1, reemplazo |
| Store | 0001      | Store MISS contenedor 1           |
| -     | -         | No se realiza acceso              |
| Load  | 0009      | Load con HIT contenedor 1         |

Trabajo 25: En la interface procesador/cache mostrada en la Figura 18, utilizada en el diseño RTL (Apéndice 2.4, Figura 45), todas las señales son entrada del multiplexor y del registro. Además, las señales sólo se almacenan en el registro si se cumple la función lógica "pc\_val and pc\_listo". Esto es, si no hay petición y "pc\_listo = '1'" no se actualiza el registro. Desde el punto de vista de la lógica se utilizan tantos multiplexores y registros como señales (pc\_dir, pc\_dato, pc\_esc y pc\_val, Figura 17). Rediseñe la interface, dibujando un esquema de circuito, de forma que se utilice el menor número de multiplexores y registros. Considere cada señal pc\_dir, pc\_dato, pc\_esc y pc\_val como un todo. Esto, si se utiliza un multiplexor o un registro contabilice una unidad., en la página 17.



Trabajo 26: Represente en un diagrama temporal de retardos los retardos de los componentes en un acierto de lectura. Suponemos que el último ciclo del productor se solapa con el estado DES en el controlador de caché. Los retardos correspondientes al productor deben indicarse en el instante más tardío en el cual es factible, teniendo en cuenta el periodo del reloj. El retardo de la comparación de etiquetas y la puerta "and" de este resultado con la lectura del campo estado tiene un retardo de 0 ns. Recuerde que las señales X\_acc y X\_esc están incluidas en la lógica de salida del autómata., en la página 18.



Trabajo 35: Finalmente construya una tabla de transiciones entre estados (Apéndice 2.7, Figura 68) donde, además, se elimine el estado LEC en una transacción load que acierta en caché. Modifique la descripción VHDL del controlador de caché de forma oportuna.

Elabore el controlador de cache con Quartus., en la página 20.

| Estados                              |     | Procesado<br>ición<br>!inicio | !Petición | lect<br>si |      | de estado<br>escr<br>si | itura<br>no |             | noria<br>nemoria<br>no |               |
|--------------------------------------|-----|-------------------------------|-----------|------------|------|-------------------------|-------------|-------------|------------------------|---------------|
| DESO<br>INI<br>ESCINI<br>DES         | INI | CMPET                         | DES0      |            |      |                         | ·           | -           |                        | ESCINI<br>DES |
| CMPET<br>LEC<br>ESPL<br>ESB<br>ESPEA |     | CMFLT                         | DES       | DES        | ESPL | ESPEA                   | ESPEF       | ESB<br>ESCP | ESPL<br>ESPEA          | DES<br>LEC    |
| ESCP<br>ESPEF                        |     |                               |           |            |      |                         |             | DES         | ESPEF                  | DES           |

Trabajo 40: Construya la tabla de transiciones entre estados del controlador de cache, donde también se especifique la lógica de salida en la segunda subfila de cada estado (activación, desactivación de las señales) (Apéndice 2.10, Figura 72). Denomine mxL a la señal que controla el multiplexor muxL (Figura 26)., en la página 22.

|              |               | Procesado        | r                |                  | Señales d                |              |                       |                      | noria .       |        |
|--------------|---------------|------------------|------------------|------------------|--------------------------|--------------|-----------------------|----------------------|---------------|--------|
| Estados      | Pet<br>inicio | ición<br>!inicio | !Petición        | led<br>si        | tura<br>no               | escr<br>si   | itura<br>no           | resp. m<br>si        | nemoria<br>no |        |
| DES0         | INI           | CMPET            | DES0             |                  |                          |              |                       |                      |               |        |
|              |               | ET_acc,          | desocupad        |                  |                          |              |                       |                      |               |        |
| INI          |               | EST_acc          | a pc_listo       |                  |                          |              |                       |                      |               | ESCINI |
|              |               |                  |                  |                  |                          |              |                       |                      |               | Locuti |
| ESCINI       |               |                  |                  |                  |                          |              |                       |                      |               | DES    |
| LJCINI       |               |                  |                  |                  |                          |              |                       |                      |               | DLJ    |
| DEC          |               | CMDET            | DEC              |                  |                          |              |                       |                      |               |        |
| DES          |               | CMPET<br>ET_acc, | DES<br>desocupad |                  |                          |              |                       |                      |               |        |
|              |               | EST_acc          | a pc_listo       |                  |                          |              |                       |                      |               |        |
| CMPET        |               |                  |                  | DES              | ESPL                     | ESPEA        | ESPEF                 |                      |               |        |
|              |               |                  |                  | leer e           | tiqueta y con            | nparar, leer | estado                |                      |               |        |
|              |               |                  |                  | lectura<br>campo | pet. lectura<br>memoria, |              | scritura<br>a, pm_esc |                      |               |        |
|              |               |                  |                  | dato,            | pm_val                   | 1110110      | , pm_ese              |                      |               |        |
| ESPL         |               |                  |                  | DAT_acc          |                          |              |                       | ESB                  | ESPL          |        |
|              |               |                  |                  |                  |                          |              |                       | muxL,                |               |        |
|              |               |                  |                  |                  |                          |              |                       | actualiza<br>campos  |               |        |
|              |               |                  |                  |                  |                          |              |                       | ET_esc,              |               |        |
|              |               |                  |                  |                  |                          |              |                       | EST_esc,<br>DAT_esc, |               |        |
| ESB          |               |                  |                  |                  |                          |              |                       | EST_DE               |               | DES    |
| ESD          |               |                  |                  |                  |                          |              |                       |                      |               | DLS    |
| ECDE A       |               |                  |                  |                  |                          |              |                       | FCCD                 | ECDE A        |        |
| ESPEA        |               |                  |                  |                  |                          |              |                       | ESCP actualiza       | ESPEA         |        |
|              |               |                  |                  |                  |                          |              |                       | campos,              |               |        |
| ESCP         |               |                  |                  |                  |                          |              |                       | DAT_esc              |               | DES    |
| LJCI         |               |                  |                  |                  |                          |              |                       |                      |               | DLJ    |
| ECDEE        |               |                  |                  |                  |                          |              |                       | DEC                  | ECDET         |        |
| <b>ESPEF</b> |               |                  |                  |                  |                          |              |                       | DES                  | ESPEF         |        |

## Trabajo 48: Analice la influencia del multiplexor muxL en el tiempo de ciclo., en la página 23.

El muxL aumenta ligeramente el tiempo de ciclo dado que es un multiplexor el cual depende de las salidas del controlador de caché y de la propia salida de datos de la caché o de los datos que llegan desde la memoria principal. Sin embargo es un ligero incremento en el tiempo de ciclo que permite enviar el dato al procesador en el mismo ciclo que llegar desde la memoria principal.

## Trabajo 53: Para este proyecto, analice la necesidad de disponer de los estados ESB y ESCP., en la página 25.

Dado que la lectura con acierto ha sido reducida a un único ciclo requerimos de los estados ESB y ESCP para actualizar los campos de la memoria caché una vez la memoria principal haya respondido a la correspondiente petición que se le haya hecho. Para eso necesitamos otro estado diferente al de esperar a la memoria principal intermedio entre dicho estado y el estado DES, los estados ESB y ESCP son los estados que lleva a cabo esa función.

Trabajo 56: Construya la tabla de transiciones entre estados del controlador de cache, donde también se especifique la lógica de salida en la segunda subfila de cada estado (activación, desactivación de las señales) (Apéndice 2.13, Figura 76)., en la página 26.

| Estados      |        | Procesador<br>tición                                               | !                          | lect                                | Señales d                         | le estado<br>escri | itura |                                                                           | noria<br>nemoria |        |
|--------------|--------|--------------------------------------------------------------------|----------------------------|-------------------------------------|-----------------------------------|--------------------|-------|---------------------------------------------------------------------------|------------------|--------|
| Litauos      | inicio | !inicio                                                            | Petición                   | si                                  | no                                | si                 | no    | si                                                                        | no               |        |
| DES0         | INI    | CMPET                                                              | DES0                       |                                     |                                   |                    |       |                                                                           |                  |        |
|              |        | ET_acc,<br>EST_acc                                                 | desocupa<br>da<br>pc_listo |                                     |                                   |                    |       |                                                                           |                  |        |
| INI          |        |                                                                    |                            |                                     |                                   |                    |       |                                                                           |                  | ESCINI |
| ESCINI       |        |                                                                    |                            |                                     |                                   |                    |       |                                                                           |                  | DES    |
| DES          |        | DES                                                                | DES                        | DES                                 | ESPL                              | ESPEA              | ESPEF |                                                                           |                  |        |
|              |        | leer etiqueta<br>y comparar,<br>leer estado,<br>ET_acc,<br>EST_acc | da                         | lectura<br>campo<br>dato<br>DAT_acc | pet. lectura<br>memoria,<br>pm_va | pet. es<br>memoria |       |                                                                           |                  |        |
| <b>ESPL</b>  |        |                                                                    |                            |                                     |                                   |                    |       | ESB                                                                       | ESPL             |        |
|              |        |                                                                    |                            |                                     |                                   |                    |       | muxL,<br>actualiza<br>campos<br>ET_esc,<br>EST_esc,<br>DAT_esc,<br>EST_DE |                  |        |
| ESB          |        |                                                                    |                            |                                     |                                   |                    |       | _                                                                         |                  | DES    |
| <b>ESPEA</b> |        |                                                                    |                            |                                     |                                   |                    |       | ESCP                                                                      | <b>ESPEA</b>     |        |
| ESCP         |        |                                                                    |                            |                                     |                                   |                    |       | actualiza<br>campos,<br>DAT_esc                                           |                  | DES    |
| ESPEF        |        |                                                                    |                            |                                     |                                   |                    |       | DES                                                                       | ESPEF            |        |

Trabajo 63: En la interface procesador/cache que se utiliza, todos los registros se actualizan cuando pc\_listo = '1'. Rediseñe la interface, dibujando un esquema de circuito, de forma que las señales de entrada, que sea posible, se almacenen en el registro sólo si hay una petición pendiente (esquema de circuito)., en la página 27.

Basándonos en el diseño del trabajo 25, obtenemos el siguiente diseño. En el podemos observar que solo se actualiza el registro si, además de las condiciones anteriores (cache lista y entrada válida) también se da rc\_val = '0'. Esto hace que en los casos de load con hit, al finalizarse la petición en el mismo ciclo rc\_val valga '1' y no se guarden datos en el registro, disminuyendo así el consumo de energía.



Trabajo 64: Represente en un diagrama temporal de retardos los retardos de los componentes en dos acierto de lectura consecutivos a direcciones distintas. El productor tarda 1 ciclo en producir accesos. Los retardos correspondientes al productor deben indicarse en el instante más tardío en el cual es factible, teniendo en cuenta el periodo del reloj. El retardo de la comparación de etiquetas y la puerta "and" de este resultado con la lectura del campo estado tiene un retardo de 0 ns., en la página 27.

|                 | 0 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 1 | 2 | 3 | 4 | 5 | 6 | 7 | 8 | 9 | 10 | 11 | 12 |
|-----------------|---|---|---|---|---|---|---|---|---|---|----|----|---|---|---|---|---|---|---|---|---|----|----|----|
|                 |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| mux_pet         |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| reg_pet         |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| estado          |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| prx_estad<br>o  |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| logi_salid<br>a |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| deco_ET         |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| deco_EST        |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| deco_DAT        |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| m_ET            |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| m_EST           |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| m_DAT           |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |
| reg_ET          |   |   |   |   |   |   |   |   |   |   |    |    |   |   |   |   |   |   |   |   |   |    |    |    |

Multiprocesadores: Práctica 2